package com.naiterui.ehp.bs.b2c.order.entity;

import lombok.Data;
import lombok.EqualsAndHashCode;

import javax.persistence.*;
import java.util.Date;

/**
 * <pre>
 *      退货订单主表
 * </pre>
 *
 * @author 王泽浩
 * @date 2019-02-19 10:27
 * @since 1.0.0
 */
@Data
@Entity
@EqualsAndHashCode(callSuper = false)
@Table(name = "e_return_order")
public class ReturnOrder implements java.io.Serializable {
    /**
     * 退货
     */
    public static final int TYPE_RETURN = 1;
    /**
     * 换货
     */
    public static final int TYPE_EXCHANGE = 2;
    /**
     * 补寄
     */
    public static final int TYPE_SUPPLEMENTARY = 3;

    /**
     * 订单状态 待提交
     */
    public static final int STATUS_TO_SUBMIT = 1;
    /**
     * 订单状态 待审核(已提交)
     */
    public static final int STATUS_TO_AUDIT = 2;
    /**
     * 订单状态 待发货（已审核）
     */
    public static final int STATUS_TO_SEND = 3;
    /**
     * 订单状态 已完成
     */
    public static final int STATUS_COMPLETE = 4;
    /**
     * 订单状态 已作废
     */
    public static final int STATUS_INVALID = 5;

    private static final long serialVersionUID = -7005881775487424507L;

    /**
     * id
     */
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    private Long id;


    /**
     * 订单号
     */
    @Column(name = "order_sn")
    private String orderSn;

    /**
     * 业务单号
     */
    @Column(name = "business_no")
    private String businessNo;

    /**
     * 退换货类型  1：退货  2:换货  3：补寄
     */
    @Column(name = "type")
    private Integer type;
    /**
     * 退货仓库ID
     */
    @Column(name = "warehouse_id")
    private Long warehouseId;
    /**
     * 换货/补寄仓库ID
     */
    @Column(name = "exchange_warehouse_id")
    private Long exchangeWarehouseId;

    /**
     * 退换货原因  1：客户原因 2：效果问题 3：促销活动 4：商品卖相  5：商品质量  6：发货速度  7：物流态度  8：包装损坏
     * 9：包装不满  10：发错商品  11：发漏商品  12：派送时效  13：系统出错  14：客服技能  15：相应速度
     * 16：正品问题  17：描述模糊  18：商品效期  19：商品定价  20：商品缺货  21：测量不准  22：物流其他
     */
    @Column(name = "return_reason")
    private Integer returnReason;

    /**
     * 退回物流公司
     */
    @Column(name = "logistics_company_id")
    private Long logisticsCompanyId;

    /**
     * 退回物流单号
     */
    @Column(name = "delivery_id")
    private String deliveryId;

    /**
     * 订单状态 1:待提交 2:待审核（已提交） 3:待发货（已审核） 4:已完成 5:已作废
     */
    @Column(name = "status")
    private Integer status;

    /**
     * 备注
     */
    @Column(name = "remark")
    private String remark;

    /**
     * 创建时间
     */
    @Column(name = "created_at")
    private Date createdAt;

    /**
     * 创建人
     */
    @Column(name = "created_by")
    private String createdBy;

    /**
     * 修改时间
     */
    @Column(name = "changed_at")
    private Date changedAt;

    /**
     * 修改人
     */
    @Column(name = "changed_by")
    private String changedBy;

    /**
     * 乐观锁
     */
    @Version
    private Integer version;

}
